<template>
	<el-container>
<!--		<el-aside width="200px" v-loading="showGrouploading">-->
<!--			<el-container>-->
<!--				<el-header>-->
<!--					<el-input placeholder="输入关键字进行过滤" v-model="groupFilterText" clearable></el-input>-->
<!--				</el-header>-->
<!--				<el-main class="nopadding">-->
<!--					<el-tree ref="group" class="menu" node-key="id" :data="group" :current-node-key="''" :highlight-current="true" :expand-on-click-node="false" :filter-node-method="groupFilterNode" @node-click="groupClick"></el-tree>-->
<!--				</el-main>-->
<!--			</el-container>-->
<!--		</el-aside>-->
		<el-container>
				<el-header>


					<div class="left-panel">
						<el-button type="primary" icon="el-icon-plus" @click="add"></el-button>
						<el-button type="danger" plain icon="el-icon-delete" :disabled="selection.length==0" @click="batch_del"></el-button>
<!--						<el-button type="primary" plain :disabled="selection.length==0">分配角色</el-button>-->
<!--						<el-button type="primary" plain :disabled="selection.length==0">密码重置</el-button>-->
					</div>
					<div class="right-panel">

						<el-select v-model.number="params.qudao" placeholder="渠道来源" @change="this.$refs.table.getData()">
							<el-option
								v-for="item in qudaoData"
								:key="item.value"
								:label="item.label"
								:value="item.value">
							</el-option>
						</el-select>
						<div class="right-panel-search">
							<el-input v-model="params.k" placeholder="用户名" clearable></el-input>
							<el-button type="primary" icon="el-icon-search" @click="this.$refs.table.getData()"></el-button>
						</div>
					</div>
				</el-header>
				<el-main class="nopadding">
					<scTable ref="table" :apiObj="apiObj" :params="params" @selection-change="selectionChange" stripe>
						<el-table-column type="selection" width="50"></el-table-column>
						<el-table-column label="ID" prop="id" width="80"></el-table-column>
						<el-table-column label="头像" width="80">
							<template #default="scope">
								<el-avatar :src="scope.row.headimgurl" size="small"></el-avatar>
							</template>
						</el-table-column>
						<el-table-column label="用户名" prop="nickname" width="150"></el-table-column>
						<el-table-column label="地区" width="150">
							<template #default="scope">
								{{scope.row.country}}{{scope.row.province?' - '+scope.row.province:''}}{{scope.row.city?' - '+scope.row.city:''}}
							</template>
						</el-table-column>
						<el-table-column label="上次登录时间" prop="create_time" width="150"></el-table-column>
						<el-table-column label="渠道来源" prop="qudao" width="150">
							<template #default="scope">
								{{scope.row.qudao==1?'微信公众号':(scope.row.qudao==2?'抖音':'快手')}}
							</template>
						</el-table-column>

						<el-table-column label="操作" fixed="right" align="right" width="140">
							<template #default="scope">
								<el-button type="text" v-if="scope.row.qudao==2" size="small" @click="Sendvideo(scope.row)">发送视频</el-button>
<!--								<el-button type="text" size="small" @click="table_edit(scope.row, scope.$index)">编辑</el-button>-->
								<el-popconfirm title="确定删除吗？" @confirm="table_del(scope.row, scope.$index)">
									<template #reference>
										<el-button type="text" size="small">删除</el-button>
									</template>
								</el-popconfirm>
							</template>
						</el-table-column>

					</scTable>
				</el-main>
		</el-container>
	</el-container>

	<el-dialog :title="titleMap[saveMode]" v-model="saveDialogVisible" :width="500" destroy-on-close>
		<save-dialog ref="saveDialog" :mode="saveMode"></save-dialog>
<!--		<template #footer>-->
<!--			<el-button @click="saveDialogVisible=false" >取 消</el-button>-->
<!--			<el-button v-if="saveMode!='show'" type="primary" @click="saveForm()" :loading="isSaveing">保 存</el-button>-->
<!--		</template>-->
	</el-dialog>

</template>

<script>
	import saveDialog from './save'


	export default {
		name: 'user',
		components: {

			saveDialog,
		},
		data() {
			return {
				saveDialogVisible: false,
				saveMode: 'add',
				titleMap: {
					add: "新增",
					edit: "编辑",
					show: "查看"
				},
				isSaveing: false,
				showGrouploading: false,
				groupFilterText: '',
				group: [],
				apiObj: this.$API.user.list,
				selection: [],
				params: {
					k: '',
					qudao:""
				},
				qudaoData:[
					{label:"全部",value:-1},
					{label:"微信公众号",value:1},
					{label:"抖音",value:2},
					{label:"快手",value:3},
				],

			}
		},
		watch: {
			groupFilterText(val) {
				this.$refs.group.filter(val);
			}
		},
		mounted() {
			// this.getGroup()
		},
		methods: {
			Sendvideo(v){
				let data = {id:v.id}
				this.$API.user.sendvideo.get(data).then((res)=>{
					if(res.code==200){
						this.$message.success(res.msg)

					}else{
						this.$message.error(res.msg)

					}
				})
			},
			//添加
			add(){
				this.saveMode = 'add';
				this.saveDialogVisible = true;
			},
			//编辑
			table_edit(row){
				this.saveMode = 'edit';
				this.saveDialogVisible = true;
				this.$nextTick(() => {
					//这里应该再次根据ID查询详情接口
					this.$refs.saveDialog.setData(row)
				})

			},
			//查看
			table_show(row){
				this.saveMode = 'show';
				this.saveDialogVisible = true;
				this.$nextTick(() => {
					//这里应该再次根据ID查询详情接口
					this.$refs.saveDialog.setData(row)
				})
			},
			//删除
			async table_del(row){
				var reqData = {id: row.id}
				var res = await this.$API.user.del.post(reqData);
				if(res.code == 200){
					this.$refs.table.getData()
					this.$message.success(res.msg)
				}else{
					this.$alert(res.msg, "提示", {type: 'error'})
				}
			},
			//批量删除
			async batch_del(){
				var res = await this.$API.user.del
				this.$confirm(`确定删除选中的 ${this.selection.length} 项吗？`, '提示', {
					type: 'warning'
				}).then(() => {
					const loading = this.$loading();
					var ids =[]
					this.selection.forEach(item => {
						ids.push(item.id);
					})
					var reqData = {id: ids.join(',')}
					res.post(reqData);
					loading.close();
					if(res.code == 200){
						this.$refs.table.getData()
						this.$message.success(res.msg)
					}else{
						this.$alert(res.msg, "提示", {type: 'error'})
					}
				}).catch(() => {

				})
			},
			//提交
			saveForm(){
				this.$refs.saveDialog.submit(async (formData) => {
					this.isSaveing = true;
					var res = await this.$API.user.save.post(formData);
					this.isSaveing = false;
					if(res.code == 200){
						//这里选择刷新整个表格 OR 插入/编辑现有表格数据
						this.saveDialogVisible = false;
						this.$message.success("操作成功")
					}else{
						this.$alert(res.message, "提示", {type: 'error'})
					}
				})
			},
			//表格选择后回调事件
			selectionChange(selection){
				this.selection = selection;
			},
			//加载树数据
			async getGroup(){
				var res = await this.$API.role.select.get();

				// console.log(res)
				this.showGrouploading = false;
				var allNode ={id: '', label: '所有'}
				res.data.unshift(allNode);
				this.group = res.data;
			},
			//树过滤
			groupFilterNode(value, data){
				if (!value) return true;
				return data.label.indexOf(value) !== -1;
			},
			//树点击事件
			groupClick(data){
				var params = {
					groupId: data.id
				}
				this.$refs.table.upData(params)
			},
			//搜索
			upsearch(){

			}
		}
	}
</script>

<style>
</style>
